不管是《21天学会XXX》还是《Java编程死象》,基本上所有的编程入门书都会反复跟你讲「强类聚,弱耦合」,我理解模块划分中很容易发生模块之间耦合严重。你的代码运行依赖他的代码,然后他改了个接口你的代码就没法运行了。
所以...
- 模块要能独立编写、运行、测试
- 模块要减少对外部参数的依赖
如果熟悉 Web 开发,会发现框架要工作需要你定义 Router , Router 的作用是一个请求来了,帮这个请求找到对应的模块,接下来怎么渲染、需要显示啥,都是 Router 背后的模块的事儿了。试想 Web 开发不用任何框架,也不写 Router,一个请求过来了,会发生啥:
def matchURL(url):
if url.find('/article'):
article = Article()
article.articleID = 1000050
article.title = '铃铛和花瓶'
return article.render()
return 'No Match'
有了 Router 之后:
urls = (
'/article/:articleID', 'article'
)
Router 的本质是一个约定、一种传参规则。
我们遇到的问题不就是 Router 解决的么?彼此之间就不需要再关心对方的模块做了啥,需要调用对方模块的时候,只需要像 Router 要,不需要去关心对方模块到底做了啥,暴露了啥接口,这样也就解藕了。
其实早在远古的 Three20 时代就有运用这种思想造出的轮子:
https://github.com/alunny/three20/blob/master/src/TTNavigator.m
然后近代的复刻版有:
https://github.com/gaosboy/urlmanager
https://github.com/Huohua/HHRouter
https://github.com/usepropeller/routable-ios
https://github.com/aaronbrethorst/ABRouter
使用上都是像 Router 注册 URL 和对应的 Controller,然后在使用的时候忘记 Controller 创建、初始化的存在,直接向 Router 去要:
//注册
[[HHRouter shared] map:@"/read/:userId/" toControllerClass:ReadController.class];
//调用
[[HHRouter shared] matchController:@"/read/1/?tabIndex=3"]
通过这种思想,模块之间的耦合度降低了,因为彼此之间传递参数都是通过URL,Controller 也更清晰。
参考资料:
http://pizi.me/86
https://github.com/gaosboy/urlmanager/
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。